Security News
Input Validation Vulnerabilities Dominate MITRE's 2024 CWE Top 25 List
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
simple-parallax-js
Advanced tools
simpleParallax is a simple JavaScript library that gives your website parallax animations on any images or videos
simpleParallax.js is a very simple and tiny Vanilla JS library that adds parallax animations on any images.
Where it may be laborious to get results through other plugins, simpleParallax.js stands out for its ease and its visual rendering. The parallax effect is directly applied to image tags, there is no need to use background images. More info on the case study here.
Any image will fit. Try it out!
Simply copy/paste the below snippet just before your closing </body>
tag:
<script src="simpleParallax.js"></script>
or use the below CDN link provided by jsDelivr.com:
<script src="https://cdn.jsdelivr.net/npm/simple-parallax-js@5.6.1/dist/simpleParallax.min.js"></script>
You can also install it via:
#npm
npm install simple-parallax-js
#yarn
yarn add simple-parallax-js
and then import it as follows:
//ES6 import
import simpleParallax from 'simple-parallax-js';
//CommonJS
const simpleParallax = require('simple-parallax-js');
Giving the following HTML:
<img class="thumbnail" src="image.jpg" alt="image">
simply add the following JavaScript code:
const image = document.getElementsByClassName('thumbnail');
new simpleParallax(image);
and voilà!
You can also choose to apply the parallax on multiple images:
const images = document.querySelectorAll('img');
new simpleParallax(images);
Once simpleparallax has been correctly initialized, it adds the simple-parallax-initialized
class on the container.
simpleParallax now works with video:
<video>
<source src="video.mp4" type="video/mp4">
</video>
var video = document.getElementsByTagName('video');
new simpleParallax(video);
Setting | Type | Default | Hint |
---|---|---|---|
orientation | String | up | up - right - down - left - up left - up right - down left - down right |
scale | Number | 1.3 | need to be above 1 |
overflow | Boolean | false | |
delay | Number | 0 | the delay is in second Watch out, sometimes this delay is causing issue on iOS devices #47 |
transition | String | '' | any CSS transition |
customContainer | String or Node | '' | |
customWrapper | String | '' | the selector of the custom wrapper |
maxTransition | Number | 0 | it should be a percentage between 1 and 99 |
You can apply these settings with the following JS code:
var images = document.querySelectorAll('.thumbnail');
new simpleParallax(images, {
delay: 0,
orientation: 'down',
scale: 1.3,
overflow: true,
customContainer: '.container',
customWrapper: '.wrapper'
});
This is the orientation (or direction) of the parallax effect. Choose up and when scrolling down, the image will translate from the bottom to the top (so the image will translate up). When scrolling up, the image will translate from the top to the bottom. Same logic applies for all others orientations (right, down, left, up left, up right, down left or down right). When 2 directions are combined (for example down right), the image will translate diagonally.
The higher the scale is set, the more visible the parallax effect will be. In return, the image will lose in quality. To reduce the lossless effect, if the scale is set at 1.5 and your image is 500px width, do the simple math 500 * 1.5 = 750. So you can choose a 750px image to replace your 500px one, and don't see any quality leak. More information is available if you read the case study here.
By default, the image is scaled to apply a parallax effect without any overflow on the layout - you can check the case study to have a better understanding. When overflow is set to true, the image will translate out of its natural flow (so it may overlap with your content).
When a delay is set, the translation of the image will continue during that delay when the user stops scrolling. That gives a very nice effect. The delay is in second. Watch out, sometimes this delay is causing issue on iOS devices #47
The transition setting works closely with the delay setting. This setting will add any CSS transition to the delay setting. For example, you can use ease or ease-in-out.
By default, the parallax calculation is done with the body scroll percentage. In some cases, the images may be in a container that has its own scroll area, so to have an accurate calculation, the custom container should be set.
In some cases, you want to use your own wrapper instead of the one created by the plugin. If you specify your custom wrapper, the plugin will add the "simpleParallax" class along with an "overflow: hidden" style.
The maxTransition setting should be used to stop the parallax animation after a given percentage. By default, it translates from 0% to 100% of the user viewport. You can change it here to any percentage you want.
Refresh a simpleParallax instance (to recalculate all the positions):
var images = document.querySelectorAll('img');
var instance = new simpleParallax(images);
instance.refresh();
By default, the refresh method is fired at every window resize.
Destroy a simpleParallax instance:
var images = document.querySelectorAll('img');
var instance = new simpleParallax(images);
instance.destroy();
You can find all the examples here.
IE | Edge | Firefox | Chrome | Safari | Opera | iOS Safari |
---|---|---|---|---|---|---|
no support | 16+ | 55+ | 58+ | 12.1+ | 45+ | 12.2+ |
Even though old browsers are not supported, the page won't crash. Simply, there will be no parallax.
If you want to support older browsers such as IE, you will need a polyfill for cloest() and Intersection Observer. Please note that even with polyfills, the parallax effect will not seem fluid.
Open an issue or a pull request to suggest changes or additions.
FAQs
simpleParallax.js is a lightweight and easy-to-use JS library that adds parallax animations to any image.
We found that simple-parallax-js demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Security News
In this segment of the Risky Business podcast, Feross Aboukhadijeh and Patrick Gray discuss the challenges of tracking malware discovered in open source softare.
Research
Security News
A threat actor's playbook for exploiting the npm ecosystem was exposed on the dark web, detailing how to build a blockchain-powered botnet.